草庐IT

Julia 元组

全部标签

c++ - 我怎样才能*有效地*从嵌套表达式生成所有类型的元组?

假设我有一些包含类型排列的模板表达式,在本例中它们来自AbstractSyntaxTree:templatestructBranch{};templatestructLeaf{};输入表达式可以是Branch的任意嵌套组合和Leaf类型,但为了简单起见,我将创建一个包含单个Leaf的线性AST包裹N层层深入Branch类型:usingExpression=Branch>;//N=2为了这个问题,我创建了一个函数来动态生成这些表达式,这样我就可以演示我在绘图方面遇到的问题。所以这里是我将用来生成我的表达式的函数://wrapLeafinBranchNnumberoftimes:templ

具有复制省略或 move 语义的 C++11 元组

我写了一个如下的函数:templatestd::tuple,T,T>f(){std::vectorp(1000);returnstd::make_tuple(std::move(p),10,10);}由于返回类型非常复杂,是否保证在c++11下编译器在构造结果时将应用复制省略或move语义,或者我必须明确地说出类似std::move(std::make_tuple(std::move(p),10,10))? 最佳答案 AFAIK复制省略始终是可选的。标准只是明确表示允许编译器进行此类优化,因为它改变了可观察到的行为,它并不强制执行。

c++ - 如何使用没有复制构造函数的给定类初始化元组

我有一个要求,需要按如下方式初始化元组。如何创建包含A类对象的元组?#include#includeusingnamespacestd;classA{inta;public:A(constA&)=delete;A(inta):a(a){}};std::tuple&createTuple(A&&a){returnstd::make_tuple(std::forward(a));}intmain(){std::cout(createTuple(std::forward(A(1))));}我不能以任何方式修改A类。 最佳答案 像这样:st

c++ - 使用 C 中内存地址的 Julia 读/写结构数据

我正在将我的应用程序嵌入到Julia中,我需要一种从Julia和C++读取/写入相同结构的好方法。在Python中我可以简单地做:ffi.cdef("""structkeyboard_s{intforward;intbackward;intleft;intright;intjump;}structkeyboard_s*app_get_keyboard();"""app=ffi.dlopen("app.dll")thekeyboard=app.app_get_keyboard();thekeyboard.forward=1;#thiswouldimmediatlychangethemem

c++ - 编译时将树转换为元组

我遇到了以下问题:给定一棵由Node类型的非终端节点表示的树和任意类型的终端节点,如A,B等等(见下文)。因为我不想使用运行时多态性,所以我喜欢将树转换为std::tuple通过constexpr其功能类似于下面示例中立即调用的lambda表达式。structA{};structB{};structC{};structD{};structE{};templatestructNode{constexprNode(constT&...n):mChildren{n...}{}std::tuplemChildren;};templatestructIndexNode{std::arraymCh

c++ - GCC ICE——替代函数语法、可变参数模板和元组

(与C++0x,HowdoIexpandatupleintovariadictemplatefunctionarguments?相关。)以下代码(见下文)取自此discussion.目标是将函数应用于元组。我简化了模板参数并修改了代码以允许返回泛型类型的值。虽然原始代码编译正常,但当我尝试使用GCC4.4.3编译修改后的代码时,g++-std=c++0xmain.cc-omainGCC报告内部编译器错误(ICE),并显示以下消息:main.cc:Infunction‘intmain()’:main.cc:53:internalcompilererror:intsubst_copy,at

c++ - GCC 中的元组模板

我首先在VS2010中使用MicrosoftVC++开始使用C++。我最近找到了一些工作,但我一直在使用RHEL5和GCC。我的代码主要是原生C++,但我注意到一件事......GCC似乎无法识别头文件或元组模板。起初我以为这可能只是一个拼写错误,直到我查看cplusplus.com发现该header确实不是标准库的一部分。问题是我喜欢在VisualStudio中编写代码,因为它的环境比eclipse或netbeans更优越、更美观,而且调试也很容易。问题是,我已经编写了大量代码来使用元组,而且我真的很喜欢我的代码。我该如何处理这个问题?这是我的代码:usingstd::cout;us

Boost.Range 的 C++ 元组 - 获取元素类型的元组?

我正在试验Boost.Range和Boost元组。如果我有一个范围元组,我如何键入定义一个元组或相应的元素值?换句话说,我用什么来代替/*?*/:typedefboost::tuples::tuple&,char[]>TupleOfRanges;typedef/*?*/TupleOfElements;我当然可以手工完成,我会写:typedefboost::tuples::tupleTupleOfElements;甚至:typedeftypenameboost::tuples::element::typeRange0;typedeftypenameboost::tuples::eleme

c++ - 调用函数并传递存储在元组中的参数?

我想要一个Foo类来存储它在构造时获得的函数指针,并在某个时候调用这个函数。我查看了这两个问题以寻求帮助:Passtuple'scontentasvariadicfunctionargumentsHowdoIexpandatupleintovariadictemplatefunction'sarguments?然后,根据答案,想出了这段代码:#includetemplatestructapply_func{staticvoidapplyTuple(std::function&f,conststd::tuple&t,ARGS...args){apply_func::applyTuple(

c++ - 是否可以从大括号类型的初始化中推断出元组的模板参数?

在这个例子中,是否可以允许推导元组的模板参数类型?#include#includetemplatevoidfun(std::tuplet,std::stringother){}intmain(){fun(std::tuple(2.,3),std::string("other"));//okfun(std::make_tuple(2.,3),std::string("other"));//ok,buttryingtoavoid`make_tuple`fun({2.,3},std::string("other"));//desiredsyntaxbut//givingcompilation